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Optimizing Server Delivery of Content By Selective Inclusion 
OF Optional Data Based on Optimization Criteria 



Inventor 

5 Taylor S. Gautier 

Background 

Field of Invention 

The present invention relates generally to systems, methods, and software 
products for delivering content in client-server networks, and more particvilarly, to 
10 systems, methods, and software products that optimize the delivery of such content in 
response to optimization criteria. 

Backgroimd of the Invention 

The Internet generally, and the World Wide Web specifically, provide a client- 
server model of content deUvery, in which content stored on a server at a web site is 

15 delivered over a communications channel to a client device. Conventionally, the 
content as structured by the author is delivered by the server to all requesting clients ia 
the same form. That is, the server does not change the structure of the content to 
accommodate the performance characteristics of the communication charmel to a 
particular client, or the performance characteristics of the client itself. At best, the cKent 

20 re-formats the received content based on its own capabilities (e.g. a text ordy browser 
will filter out images, but still must receive the images, thereby consuming bandwidth). 

This delivery model is not satisfactory when there are many different types of 
clients, with varying performance capabilities and varying commtmication channels. 
For example, today a web site may be accessed by many different types of cHents, from 

25 conventional full size computers with large screen displays (e.g. 13" to 17") and full 
color capabilities (16M colors) to small handheld computers with small screens (e.g. 4" 
to 6") and limited color capabilities (256 colors), to cellular telephones with very small 
screens (1" -2") and virtually no color capabilities (2-8 colors monochrome). A web 
page with many images that is designed to be viewed on a full size, fuU color monitor 

30 will not appear at all properly on a cellular telephone display with only monochrome 
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output. Moreover, the ceEular telephone has a much lower bandwidth capability than a 
standard desktop computer, and thus would require significantly more time (and hence 
more cost and delay) in loading such a web page. 

Typically, in order to accommodate these varying capabilities, a server must 

5 maintain many different web sites or web pages, each designed to be served to a 
particular class of client. But this approach is very labor intensive, particularly for sites 
that must be updated frequently, since tihie many different sizes and content selections 
for a given page must be kept in synchrony to all have the same current content 
Further, display capabilities are only one characteristic that affects client performance. 

10 Different client devices may operate with different bandwidth capabilities, having 
different processor and memory capacities, or even have different pricing schemes 
associated with retrieval of content. When considering the possible combinations of 
factors that affect client performance, such as bandwidth and display capabilities (to 
name just two), the number of different possible web sites that need to be maintained 

15 quickly becomes unmanageable. 

An alternative solution to maintaining multiple web sites is to design web sites 
that are acceptable to only the lowest performance devices that are going to access the 
site. But this approach yields simple sites that do not fully allow higher performance 
devices to take advantage of their performance features. 

20 Accordingly, it is desirable to provide a system, method, and software product 

that can optimize delivery of content to client devices in response to optimization 
criteria. In particular, it is desirable to provide a web server that can efficiently deliver 
content to client devices having varying bandwidth, display, and other performance 
characteristics. 

25 Summary of the Invention 

The present invention overcomes the limitations of the conventional systems by 
providing a server software product and a method that selectively delivers content to a 
client in response to optimization constraints indicative of the client's performance 
characteristics. The server delivers content such as web pages, images, text, audio, 

30 video, and any other data types to varying client devices with varying performance 
characteristics. 
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The present invention augments existing markup languages with a new tag that 
demarcates a group of one or more content items that may be optionally included in the 
content to be deUvered. Where there are mtiltiple optional items in a group, these itemis 
are alternatives for inclusion in the content, and one of the items is selected by the 

5 server for inclusion in the content based on an optimization constraint dependent on the 
characteristics of the client device. 

Preferably, the items are ordered in a manner corresponding to some set of cUent 
characteristics; one of these items is selected as the content to be delivered when the 
content is requested. The characteristics inay be performance characteristics of the client 

10 or communication charmel, or other attributes of the cHent. For example, the ordering of 
optional content items may be with respect to highest performance to lowest 
performance devices, or vice versa. For example, in web page providing directions to a 
desired location, a group of optional content may include first an image of a map 
illustrating the directions, followed by a detailed text description of the directions, 

15 followed by a very short text description of the directions. Thus, each of these items is 
intended for different types of client devices, which can best receive and display the 
directions in one of these formats, and one of these forms of information will be 
delivered to a requesting client. 

When the server is processing a client request for the document, any content that 

20 is demarcated as being optional is included in the delivered content depending on the 
performance characteristics of client that is requesting the content. More particularly, 
the server processes the items of optional content in the order in which they are 
demarcated together. Thus, in an embodiment in which optional items are ordered 
from highest to lowest performance capability, if the requesting client is a high 

25 performance device (including having a high bandwidth connection), then the first item 
of content is included in the document; if the requesting cKent is a low performance 
device, then the first item(s) is skipped until the appropriate item of content is reached. 
Obviously, the reverse of this ordering and selection process is possible. The selection 
of which item of content is appropriate for which client device is based on an 

30 optimization constraint. The server stores data which associates different types of client 
devices or performance characteristics with different levels of the optimization 
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constraint. The number of different types of client devices or performance 
characteristics is not limited. The server selects the appropriate optimization constraint 
based on observable characteristics of the client device requesting the content. These 
observable characteristics include the device type, browser type, operating system, 

5 processor, memory, user preferences, software installed on the client, and language type 
for the requested content. 

A set of selection rules is used by the server to select which of tiie optional items 
of content are to be deUvered to the client device based on the optimization constraint 
More particularly, the rules map any optimization constraint to one of the items of 

10 content. In a preferred embodiment, where the optional items are ordered with respect 
to their performance demands, the optimization constraint is used as an index into 
these items to select the appropriate one for the client The process may be understood 
as one of selectively reducing the data stream provided to a specific cHent based on 
encoding of optionally selectable/filterable data, and an optimization constraint value 

15 that controls the selection process. 

The tag that demarcates optional content can obviously be any useful string. In 
one embodiment, the tag is usefully called the "OPT" tag. The OPT tag is formatted 
using standard SGML formats, with <OPT> indicating the beginning of the optional 
content, and terminated by </OPT> indicating the end of the optional content. Within 

20 the OPT tag there may be zero or more delimiting tags separating alternative items of 
optional content The preferred delimiting tag for separating altemative items is 
<DOPT> for "Delimiting OPTion". A well formed OPT tag has the following form: 
<OPT> content {<DOVT>altemative contentY</OVT> 

Zero or more <DOPT> tags with their corresponding altemative content foUow in 
25 an order, which may be from highest to lowest performance requirements, or vice versa. 
In the former ordering, this typically means from largest data size (e.g. length of text or 
use of images) to smallest data size. 

Examples: 

1. <OPT>Real Time Stock </OPT>Quotes 
30 2. <OPT>Tum left<DOPT>Left<DOPT>L</OPT> on First Street 
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In ttie first example, the optional content "Real Time Stock" is delivered orUy to 
client devices that have no performance limitations, e.g. are not bandwidth limited, and 
so receive the complete text "Real Time Stock Quotes". A client device that has any 
optimization constraint only receives "Quotes" when this content is delivered. Thus, 

5 the tmconstrained version is appropriate, for example, for a standard desktop computer, 
but the latter version is better supplied to a device with a very small screen or low 
bandwidth capabilities, such as a cellular telephone. 

In the second example, of directions being given to a location, the alternative 
content selections become progressively smaller, being ordered left to right from least 

10 constrained (highest performance) to most constrained (lowest performance). Thus, the 
first item "Turn left" is delivered to a high performance client, while the last item "L" is 
suitable for client devices with lower bandwidth and/ or smaller displays. 

One preferred method of using the optimization constraint as an index into the 
optional items of content uses both positive and negative numbers as optimization 

15 constraints. Positive numbers index from least constrained items to most constrained 
items. In example 2) above, an optimization constraint of (1) would select "Turn left" 
while an optimization constraint of (2) would select "Left". Negative numbers index 
from most constrained to least; thus (-1) would select "L", which (-2) would also select 
"Left". Preferably, positive one (1) always selects the least constrained item, and 

20 negative one (-1) selects the most constrained item; zero (0) is treated as negative one (- 
1), It is preferable rule that a negative number may never select the least constrained 
most item, and a positive number may never select the most constrained item. With 
these rules, any number of optional items of content may encoded in the document and 
selectively delivered. Again, whether the ordering is left to right or right to left for high 

25 to low constraint is an implementation detail; which ever is used, the selection logic is 
implemented to match. 

Using the present invention, it is possible to build a single server which is 
capable of serving information to multiple clients, over varying bandwidth cormections, 
or with other varying performance characteristics. 
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The amount of effort required to support a growing number of clients is reduced 
from an order of 0(2) [for a traditional system], or a square relationship, to an order of 
0(1), or a linear relatioiiship. 

This savings of effort required to maintain such a server brings the possibility of 
serving data to a wide range of client devices over a broad scale of bandwidth 
connections to a reality. 
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Brief Description of the Drawings 
Fig. 1 is an illustration of a system in accordance with the present invention. 
Fig. 2 is an illustration of a method of operating a server in accordance with the 
present invention. 

Figs. 3a-3c illustrates an example of an encoded content item with optional 
content, and different outputs of optional content according to varying levels of 
optimization coristraint. 
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Detailed Description of the Preferred Embodiments 
Referring to Fig, 1, there is shown an illustration of a system in accordance witii 
the present invention. The system includes a server 102 and a content database 100. 
The server 102 of interest is the software product that executes on a conventional server 
5 grade computer, such as a workstation, minicomputer, mainframe, or the like. The 
server 102 is configured to execute in accordance with the ftmctional features as 
described herein. 

The content database 100 stores content in a suitable format, such as a markup 
language, ASCII, and the Hke. Suitable markup languages include HyperText Markup 

10 Language (HTML), Extended Markup Language (XML), Hypertext Dynamic Markup 
Language (HDML), Tagged Text Markup Language (TTML). The server 102 is then a 
server of the appropriate t5^e of markup language, and includes fimctions for receiving 
requests for a content item, typically indicated by a imiform resource locator (URL), and 
parsing markup language tags, creating a content item in resporise to a request, and 

15 transmitting the content item to the requesting client. 

Some of the content in the database 100 is structured to include at least one item 
of optional content demarcated by a specific markup language tag. The preferred tag is 
<OPT>, as described above, and its terminating tag </OPT>. Any number of alternate 
items of content may be enclosed, each delimited by a specific tag, such as <DOPT>. 

20 The items are preferably ordered with respect to some performance criteria, such as 
bandwidth capability. One ordering is from left to right, from lowest constraint, highest 
performance devices, to highest constraint, lowest performance devices. Schematically, 
a portion of content structured in this manner is as follows: 

<OFI>lowest constraint data<DOVI>next lowest constraint<DO¥I>. ...<DOVT>highest 

25 constraint data< / OPT>. 

In one embodiment, these tags are part of meta-language that itself marks up 
other markup languages. In this embodiment, the OPT and DOPT are set off by « and 
», to indicate to the server 102 that they are part of the meta-language, and not part of 
the xmderlying markup language. In this manner, any number of different markup 

30 language content items are stored in the database 100, and they are marked up in the 
meta-language. Various different client devices use various different ones of the 
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markup languages. Client device specific pages are thus constructed in the different 
markup languages. These client specific pages are marked up with the meta-language 
tags, and here particularly the OPT tag is used to specify optional content that can be 
merged or integrated into the client specific pages. In a preferred embodiment, the 

5 content within the OPT tags is variable data selected from the database 100 in response 
to a query; the server filters the query response using the OPT mechanism described 
herein. The server 102 can thus deliver content in any of the markup languages, and 
with any of the optionally defined content to any requesting client; this allows different 
clients which use different markup languages to interface with the server 102. 

10 The server 102 communicates with various types of client devices 106 over a 

communications network 104. The client devices 106 include desktop and laptop 
computers, pocket organizers, personal digital assistants, cellular telephones, and any 
other type of commtmication device adapted for Internet or Web based commtmications 
(i.e. HTTP). The server 102 selectively provides optional content from a content item, 

15 depending on an optimization constraint associated with a requesting client device 106. 

Referring to Fig. 2, there is shown a method in accordance with the present 
invention. The server 102 receives 200 a request for a content item from the database 
100. The server 102 determines 202 an optimization constraint associated with the 
requesting client device. The server 102 compiles 204 the requested content item, 

20 including selectively including content that is set forth as optional content, and if 
necessary, by selecting one of the alternate items of content, based on the optimization 
constraint. The server 102 then transmits 206 the compiled content item to the client. 
Determining the optimization constraint preferably includes determining either a client 
device type, client operating system type, cUent browser type, content language type of 

25 the requested content, communication bandwidth of the client, client processor, 
memory, user preferences, or software installed on the client, or a combination of any of 
these or other attributes. Selecting one of the alternate items preferably includes 
applying a set of rules that map the optimization constraint to selected ones of the 
optional content items. 
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One set of rales uses the optimization constraint as an index, where the items are 
ordered in manner corresponding to performance capabilities of the client devices. This 
set of rules is described as follows: 

1. Determine the number of optional items. If only one is available, add a blank 
option as the rightmost (most constrained) option. 

2. Retrieve the optimization constraint which corresponds to the client device. 

3. Positive numbers select from least constrained to most constrained. Negative 
numbers select from most constrained to least constrained. 

4. The positive number one (1) selects Ae least constrained item. 

5. The negative number one (-1) selects the most constrained item. 

6. The number zero (0) is equivalent to negative one (-1) 

7. Use the optimization constraint as an index into the optional items, where 1 
selects the least constrained item, 2 the second least constrained item, and so on; -1 
selects the most constrained item, -2 selects the second to most constrained item and so 
on. 

8. A negative number may never select the least constrained item. 

9. A positive ntimber may never select the most constrained item. 

The following table illustrates an example mapping where there are 5 items of 
alternate content, using a left to right, least to most constraint ordering: 



Table 1 





l^t Item 

(Least Constrained) 


2^d Item 


3^<i Item 


Item 


5^ Item 

(most constrained) 


Opt. 
Constraint n 
which selects 
this item: 


n=l 


n=2, 
n<=-4 


n=(3,-3) 


n>=4, 
n=-2 


n=(-l, 0) 



In one embodiment, the optimization constraint is defined with respect to the 
markup language of the content being served. The next table defines one set of 
optimization constraints for this embodiment: 
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Table 2 



Language / Bandwith 


Optimization Constraint 


HTML (on Tl connection at 
1.5Mb/s) 


1 


HTML (wired modem <=56Kb/s) 


2 


HTML (wireless <=9600 bps) 


-3 


HDML(<9600bps) 


-2 


TTML 


-1 



The assigtunent of optiimzation constraints based on content language is a 
reflection of the typical bandwidth limitations of client devices that use the specific 
content language. HTML is generally used in a desktop environment where connection 

5 speeds are relatively high and display capacities are also relatively high, and thus a low 
constraint is appropriate, particularly for HTML on a Tl connection. HTML on a 
wireless device, such as a PDA is more constrained, and hence a higher constraint 
HDML is generally used in a digital cellular telephone communications arena, with a 
transmission speed limited to 9600 bps and size of messages limited to the telephone 

10 memory, hence even more constrained environment, as reflected by the optimization 
constraint. TTML is generally used over GSM style SMS messages which are limited to 
160 characters, and thus is the most constrained environment, and thus given a -1 
optimization constraint. 

As the server 102 scans an item of content, it comes across an OPT encoded item 

15 of data. The server 102 can determine the optimization constraint based on the markup 
language as in Table 2, or using any other set of rules mapping information about the 
client device attributes to an optimization value. The determined value is then used as 
an index into the items of DOPT portions, to select the appropriate item of content. This 
process is repeated for each OPT encoded portion of the requested content, so that the 

20 server 102 ultimately compiles a complete content item. The completed content item is 
transmitted to the client device. 

Figs. 3a-3c illustrates a more complex example of the present invention. Here, a 
content item 300 in Fig. 3a is encoded in a markup language, along with multiple 
portions set out as optional content between OPT tags, some of which have multiple 

25 alternate items delimited by DOPT tags. Fig. 3b illustrates the output of this content 
item by selection for a least constrained environment, HTML over Tl. Note that all of 
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the optional text in each OPT section is included. Fig. 3c illustrates output of this same 
content item by selection for the most constrained items for a TTML environment As is 
apparent then, a single content item may be easily structured to serve multiple different 
client devices, without having to maintain many different versions of the content item, 
as in conventional systems. 
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Claims 

1 1. A method of optimizing the deKvery of content data from a web server to a 

2 client device, said method comprising: 

3 receiving a request for content data from a client device; 

4 selecting optional content of the content data responsive to performance 

5 characteristics of the requesting client device; and 

6 transmitting the selected optional content to the requesting client device. 

1 2. The method of claim 1 wherein selecting optional content further comprises: 

2 selecting one of a plurality of content items responsive to the 

3 performance characteristics of the requesting client device. 

1 3. The method of claim 2 whereki the plraality of content items is ordered with 

2 respect to highest and lowest performance characteristics of client devices, and selecting 

3 comprises: 

4 responsive to a client device having a highest performance characteristic, 

5 selecting a first ordered content item. 

1 4. The method of claim 2 wherein the plurality of content items is ordered with 

2 respect to highest and lowest performance characteristics of client devices, and selecting 

3 further comprises: 

4 responsive to a client device having a highest performance characteristic, 

5 selecting a last ordered content item. 

1 5. The method of claim 3 wherein optimization constraints are assigned to classes 

2 of client devices, and each class of client device has different performance 

3 characteristics, further comprising: 

4 determining the performance characteristics of the requesting client 

5 device; 

6 determining a class of client device to which the requesting client device 

7 belongs responsive to the determined performance characteristics 

8 of the requesting client device; 
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9 assigning the requesting client device an optimization constraint 

10 responsive to the determined class of client device to which the 

11 requesting client device belongs; and 

12 selecting comprises selecting a content item whose order corresponds to 

13 the optimization constraint 

1 6. The method of claim 5 further comprising: 

2 responsive to an optimization constraint specifying a class of device 

3 having a lowest performance characteristic, selecting a content 

4 item requiring a least amount of bandwidth to be transmitted. 

1 7, The method of claim 5 further comprising: 

2 responsive to an optimization constraint specifying a class of device 

3 having a lowest performance characteristic, selecting a content 

4 item comprising a least amoxmt of data. 

1 8. The method of claim 2 wherein optimization constraints are associated with each 

2 content item, and the optimization constraints index classes of client devices, wherein 

3 each class of client device has different performance characteristics, further comprising: 

4 assigning the requesting client device an optimization constraint 

5 responsive to the performance characteristics of the requesting 

6 client device; and 

7 selecting comprises selecting a content item responsive to the assigned 

8 Optimization constraint. 

1 9. The method of claim 8 wherein assigning an optimization constraint responsive 

2 to the performance characteristics of the requesting client device further comprises: 

3 determining a cormection type in use by the client device; and 

4 associating an optimization constraint responsive to the cormection type 

5 of the client device. 

1 10. The method of claim 8 wherein assigning an optimization constraint responsive 

2 to the performance characteristics of the requesting client device further comprises: 
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3 determining a web browser in use by the requesting client device; and 

4 associating an optimization constraint further comprises: 

5 associating an optimization constraint responsive to the web browser in 

6 use by the requesting client device. 

1 11. The method of claim 8 wherein assigtung an optimization coristraint responsive 

2 to the performance characteristics of the requesting client device further comprises: 

3 determining a processor type in use by the requesting client device; and 

4 associating an optimization constraint further comprises: 

5 associating an optimization constraint responsive to the processor type in 

6 use by the requesting client device. 

1 12. The method of claim 8 wherein assigning an optimization constraint responsive 

2 to iiie performance characteristics of the requesting client device further comprises: 

3 determining an amount of memory in use by the requesting client device; 

4 and associating an optimization constraint further comprises: 

5 associating an optimization constraint responsive to the amount of 

6 memory in use by the requesting client device. 

1 13. The method of claim 8 wherein assigning an optimization constraint responsive 

2 to the performance characteristics of the requesting client device further comprises: 

3 determining a display type in use by the requesting client device; and 

4 associating an optimization coristraint further comprises: 

5 associating an optimization constraint responsive to the display type in 

6 use by the requesting cHent device. 

1 14. A system for transmitting content data over a network, comprising: 

2 a content server, for receiving a request for content from a client device, 

3 selecting optional content of the content data responsive to 

4 performance characteristics of the client device, and transmitting 

5 the selected optional content to the requesting client device. 
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2 15. The system of claim 14 further comprising a plurality of client devices, for 

2 transmitting requests for content to the content server and receiving content transmitted 

3 from tiie content server, at least one client device having different performance 

4 characteristics than at least one other client device. 

2 16. The system of claim 14 wherein optimization constraints index classes of client 

2 devices based upon performance characteristics and the optional content within a 

3 context data is indexed by the optimization constraints, and the content server selects 

4 optional content from the context data responsive to assigriing an optimization 

5 constraint to a requesting client device. 

1 17. A method of creating an electronic document forming a collection of content 

2 data to permit selective transmission of content data, comprising: 

3 creating content data representing altemate versions of content; 

4 inserting the content data into the content; and 

5 demarcating the content data to indicate to a processor that the content 

6 data are selectable. 

1 18. The method of claim 17 wherein the content items have different data sizes, and 

2 inserting the content items further comprises: 

3 ordering the content items with respect to an amoxmt of bandwidth 

4 required to transmit the content items. 

1 19. The method of claim 17 in a system in which chent devices receive the electronic 

2 documents for display, and the client devices have different performance characteristics 

3 and inserting the content items further comprises: 

4 ordering the content items with respect to performance characteristics of 

5 cUent devices. 

1 20. A method of deHvering a web page comprising: 

2 receiving a request for transmission of the web page from a remote 

3 device; 

4 determining at least one performance characteristic of the remote device; 
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5 selecting optional content of the web page responsive to the determined 

6 at least one performance characteristic; and 

7 transmitting the selected optional content to the remote device. 

1 21 . The method of claim 20 wherein selecting optional content further comprises: 

2 selecting one of a plurality of content items resporisive to the 

3 performance characteristics of the requesting client device. 

1 22. The method of claim 21 wherein the plurality of content items is ordered with 

2 respect to highest and lowest performance characteristics of client devices, and selecting 

3 comprises: 

4 responsive to a client device having a highest performance characteristic, 

5 selecting a first ordered content item. 

1 23. The method of claim 21 wherein the pluraUty of content items is ordered with 

2 respect to highest and lowest performance characteristics of client devices, and selecting 

3 further comprises: 

4 responsive to a client device having a highest performance characteristic, 

5 selecting a last ordered content item. 

1 24. The method of claim 22 wherein optimization constraints are assigned to classes 

2 of client devices, and each class of client device has different performance 

3 characteristics, further comprising: 

4 determining the performance characteristics of the requesting client 

5 device; 

6 determining a class of client device to which the requesting client device 

7 belongs responsive to the determined performance characteristics 

8 of the requesting client device; 

9 assigning the requesting client device an optimization constraint 

10 responsive to the determined class of client device to which the 

1 1 requesting client device belongs; and 
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selecting comprises selecting a content item whose order corresponds to 
title optimization constraint. 



1 25. The method of claim 24 further comprising: 

2 responsive to an optimization constraint specifying a class of device 

3 having a lowest performance characteristic, selecting a content 

4 item requiring a least amoimt of bandwidth to be transmitted. 

1 26. The method of claim 24 further comprising: 

2 responsive to an optimization constraint specifying a class of device 

3 having a lowest performance characteristic, selecting a content 

4 item comprising a least amoimt of data. 

1 27. The method of claim 21 wherein optimization constraints are associated with 

2 each content item, and the optimization constraints radex classes of client devices, 

3 wherein each class of client device has different performance characteristics, further 

4 comprising: 

5 assigning the requesting client device an optimization cotiiStraint 

6 responsive to the performance characteristics of the requesting 

7 client device; and 

8 selecting comprises selecting a content item resporisive to the assigned 

9 optimization constraint. 

1 28. The method of claim 27 wherein assigning an optimization coristraint responsive 

2 to tiie performance characteristics of the requesting client device further comprises: 

3 determining a cormection type in use by the client device; and 

4 associating an optimization constraint responsive to the cormection type 

5 of the chent device. 

1 29. The method of claim 27 wherein assigning an optimization constraint responsive 

2 to the performance characteristics of the requesting client device further comprises: 

3 determining a web browser in use by the requesting client device; and 

4 associating an optimization constraint further comprises: 
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5 associating an optimization constraint responsive to the web browser in 

6 use by the requesting client device. 

1 30. A computer-readable medium for use in a system having a web server for 

2 Storing content data, and which is cormected to a plurality of client devices, the 

3 computer-readable medium storing instructions which cause the server to: 

4 receive a request for content data from a client device; 

5 select optional content of the content data responsive to performance 

6 characteristics of the requesting client device; and 

7 transmit the selected optional content to the client device. 

1 31 . The computer-readable medium of claim 30 wherein the stored instructions 

2 fur&er cause the processor to: 

3 select one of a plurality of content items responsive to the performance 

4 characteristics of the requesting client device. 

1 32. The computer-readable medium of claim 31 wherein the plurality of content 

2 items is ordered with respect to performance characteristics of client devices, and the 

3 stored instructions further cause the processor to: 

4 responsive to a client device having a highest performance characteristic, 

5 select a first ordered content item. 

1 33. The computer-readable meditmi of claim 31 wherein optimization constraints 

2 are assigned to classes of client devices, and each class of client device has different 

3 performance characteristics, and the stored instructions further cause the processor to: 

4 determine the performance characteristics of the requesting client device; 

5 determine a class of client device to which the requesting client device 

6 belong responsive to the performance characteristics of the 

7 requesting client device; 

8 assign the requesting client device an optimization constraint responsive 

9 to the determined class of client device to which the requesting 
10 client device belongs; and 
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11 select a content item corresponding to the optimization constraint 

1 34. The computer-readable meditrai of claim 32 wherein optimization constraints 

2 are associated with each content item, and the optimization constraints index classes of 

3 client devices, wherein each class of client device has different performance 

4 characteristics, and the stored instructions further cause the processor to: 

5 assign the requesting client device an optimization constraint responsive 

6 to the performance characteristics of the requesting cUent device; 

7 and 

8 select a content item responsive to the assigned optimization constraint. 

1 35. The computer-readable medium of claim 34 wherein the stored instructions 

2 further cause the processor to: 

3 determine a connection type in use by the client device; and 

4 associate an optimization coristraint responsive to the connection type of 

5 die client device, 

1 36. A method of optimizing the delivery of content data from a web server to a 

2 client device, wherein the content data is comprised of content items, optimization 

3 constraints are associated with each content item, the optimization constraints index 

4 classes of client devices, and wherein each class of client device has different 

5 performance characteristics, the method comprising: 

6 receiving a request for content data from the client device; 

7 determining a class of device to which the requesting client device 

8 belongs responsive to the performance characteristics of the 

9 requesting client device; 

10 assigning the requesting client device an optimization constraint 

n responsive to the determined class of client device; 

12 selecting one of a plurality of content items responsive to the assigned 
23 optimization constraint; and 

14 transmitting the selected optional content to the client device. 
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1 37. In a system in which a content server provides content to client devices, an 

2 optional content indicating system for demarcating optional content for transmission, 

3 comprising: 

4 a <OPT> tag, placed before a content item to indicate a beginning of 

5 optional content; 

6 a <DOPT> tag, placed before a content item which is an alternative for 

7 transmission to the content item demarcated by the<OPT> tag; 
S and 

9 a </OPT> tag, placed after a content item, to indicate an end of the 

1 0 optional content. 
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Optimizing Server Delivery of Content By Selective Inclusion of Optional 
Data Based on Optimization Criteria 

Abstract of the Disclosure 
Optimization constraints are used to select an appropriate content item from an 

5 available group of content items which are ordered in a specific maimer to facilitate the 
proper selection of the content item, even if the exact item desired is not present. The 
server is then able to insert the selected content item into the outgoing content page 
requested by the client. The optimization constraints can be, but are not limited to, any 
one of the following: communication charmel performance (bandwidth), client 

10 operating system, client processor, client display capabilities, client installed software 
(video or audio codecs for example), and/ or user preferences, A software product and 
method enable selective delivery of content to client devices of varying performance 
characteristics, including varying bandwidth, by selective filtering and inclusion of 
markup language content using tags demarcating optional content. The optional 

15 content may include a number of alternate items of content. An optimization constraint 
is used to select one of the items. The server includes the selected item in an item of 
content requested by a client device. The optimization constraints are associated with 
varying levels of client/ communication channel performance. 
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Directions<OPT> to our offices<OPT>:<BR> 

<OPT>CONTiNUE<DOPT>C</OPT><OPT> onto</OPT> HARRISON ST<OPT> 
-></OPT> <OPT>Go </OPT><OPT>a short distance<DOPT>short 
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